<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
  <title>菜单管理</title>
  <meta http-equiv="Access-Control-Allow-Origin" content="*">
  <link rel="stylesheet" href="/layui/css/layui.css">
</head>
<body>
<!-- 搜索栏 -->
<div class="searchBar">
  名称：
  <div class="layui-inline">
    <input class="layui-input" name="name" id="name" autocomplete="off" />
  </div>
  <button class="layui-btn" id="searchBtn" dataType="reload">搜索</button>
</div>
<!--表格-->
<table id="menu" lay-filter="menu"></table>
<!--工具栏-->
<div id="toolbar" style="display: none">
  <div class="layui-btn-group">
    <button class="layui-btn layui-btn-sm" lay-event="add">添加</button>
  </div>
</div>
<!--操作栏-->
<script type="text/html" id="operateBar">
  <a class="layui-btn layui-btn-sm" lay-event="edit">编辑</a>
  <a class="layui-btn layui-btn-sm layui-btn-danger" lay-event="delete">删除
  </a>
</script>
<!--模态框-->
<div id="modal" style="display: none;">
  <form class="layui-form" lay-filter="entity">
    <input type="text" name="id" style="display: none;" />
    <div class="layui-form-item">
      <label class="layui-form-label">上级目录</label>
      <div class="layui-input-inline">
        <select name="parentId" id="parentId">
        </select>
      </div>
    </div>
    <div class="layui-form-item">
      <label class="layui-form-label">菜单类型</label>
      <div class="layui-input-inline">
        <input type="radio" name="menuType" value="M" title="目录"
               checked=""><div class="layui-unselect layui-form-radio"><i class="layui-anim layui-icon"> </i><div>目录</div></div>
        <input type="radio" name="menuType" value="C" title="菜单"><div
              class="layui-unselect layui-form-radio layui-form-radioed"><i class="layui-anim layui-icon"> </i><div>菜单</div></div>
      </div>
    </div>
    <div class="layui-form-item layui-form-text">
      <label class="layui-form-label">菜单名称</label>
      <div class="layui-input-inline">
        <input type="text" name="menuName" required lay-verify="required" placeholder="请输入菜单名称" autocomplete="off" class="layui-input">
      </div>
    </div>
    <div class="layui-form-item layui-form-text">
      <label class="layui-form-label">显示顺序</label>
      <div class="layui-input-inline">
        <input type="text" name="orderNum" required lay-verify="required" placeholder="请输入显示顺序" autocomplete="off" class="layui-input">
      </div>
    </div>
    <div class="layui-form-item layui-form-text">
      <label class="layui-form-label">请求地址</label>
      <div class="layui-input-inline">
        <input type="text" name="url" required lay-verify="required"
               placeholder="请输入请求地址" autocomplete="off" class="layui-input">
      </div>
    </div>
    <div class="layui-form-item layui-form-text">
      <label class="layui-form-label">权限标识</label>
      <div class="layui-input-inline">
        <input type="text" name="perms" required lay-verify="required"
               placeholder="请输入权限标识" autocomplete="off" class="layui-input">
      </div>
    </div>
    <div class="layui-form-item">
      <label class="layui-form-label">状态</label>
      <div class="layui-input-inline">
        <input type="radio" name="visible" value="0" title="显示"
               checked=""><div class="layui-unselect layui-form-radio"><i class="layui-anim layui-icon"> </i><div>显示</div></div>
        <input type="radio" name="visible" value="1" title="隐藏"><div
              class="layui-unselect layui-form-radio layui-form-radioed"><i class="layui-anim layui-icon"> </i><div>隐藏</div></div>
      </div>
    </div>
    <div class="layui-form-item layui-form-text">
      <label class="layui-form-label">备注</label>
      <div class="layui-input-inline">
        <textarea name="remark" placeholder="请输入备注" class="layui-textarea"></textarea>
      </div>
    </div>
    <div class="layui-form-item">
      <div class="layui-input-inline">
        <button class="layui-btn" lay-submit="" lay-filter="addandupdate">立即提交</button>
        <button type="reset" class="layui-btn layui-btn-primary">重置
        </button>
      </div>
    </div>
  </form>
</div>

<script src="/layui/layui.js"></script>
<script>
  layui.use(['table','layer','jquery','form'], function(){
    var table = layui.table;
    var layer = layui.layer;
    var $ = layui.jquery;
    var form = layui.form;

    $.get("/api/menu", function (res) {
      $("#parentId").empty(); // 请求下拉框
      $("#parentId").append(new Option("请选择", 0));
      $.each(res.data, function (index, obj) {
        if (obj.parentId == 0) {
          $("#parentId").append(new Option(obj.menuName, obj.menuId));
        }
      });
      layui.form.render("select");
    });


    table.render({
      elem: '#menu'
      ,id:'testReload'
      ,height: 525
      ,url: '/api/menu/page' //数据接口
      ,page: true //开启分页
      ,cols: [[ //表头
        {field: 'menuId', title: 'ID', sort: true, fixed: 'left'}
        ,{field: 'menuName', title: '菜单名称'}
        ,{field: 'orderNum', title: '显示顺序', sort: true}
        ,{field: 'url', title: '请求地址'}
        ,{field: 'perms', title: '权限标识'}
        ,{field: 'createTime'
          ,title: '创建时间'
          ,sort: true
          ,templet: "<div>{{layui.util.toDateString(d.createTime,'yyyy-MM-dd HH:mm:ss')}}</div>"}
            ,{field: 'remark', title: '备注'}
            ,{title: '操作', toolbar: '#operateBar', align:'center'}
        ]]
        ,toolbar:'#toolbar'
        ,response : {
          statusCode : 1
    }
  ,parseData : function (res) {
      if (res.status == 1) {
        return {
          'code': res.status,
          'msg': res.message,
          'count': res.total,
          'data': res.data
        }
      }
    }
  });
    table.on("toolbar(menu)", function (obj) {
      switch (obj.event) {
        case 'add':
          open2("新增菜单", null);
          break;
      }
    });

    table.on('tool(menu)', function (obj){
      var data = obj.data;
      console.log(data);
      switch (obj.event){
        case 'delete':
          layer.confirm('确定删除吗？',function (index){
            $.ajax({
              url: '/api/menu/'+data.menuId,
              type: 'delete',
              dataType:'json',
              success:function (res){
                if (res.status == 1){
                  layer.msg(res.message);
                  obj.del();
                }else{
                  layer.msg(res.message);
                }
              }
            })
            layer.close(index);
          });
          break;
        case 'edit':
          open2("修改菜单",data);
          break;
      }
    });
    function open2(title, entity){
      form.val('entity', entity);
      layer.open({
        type : 1
        ,title : title
        ,content : $('#modal')
        ,offset: '10px'
        ,area: ['500px', '95%']
        ,end : function () {
          table.reload('testReload')
          //active.reload();
        }
      });
    }
    var active= {
      reload : function(){
        var name = $('#name');
        // 重新加载表
        table.reload('testReload', {
          page:{
            curr : 1
          }
          ,where : {
            "menuName" : name.val()
          }
        })
      }
    };
    form.on('submit(addandupdate)',function (){
      //取出表单中的值
      var data = form.val("entity");
      //console.log(data);
      //表单中的值发送到服务器
      var type = data.menuId ? 'put' : 'post';
      $.ajax({
        url:'/api/menu',
        type:type,
        dataType: 'json',
        contentType:'application/json',
        data: JSON.stringify(data),
        success:function (res){
          if(res.status == 1){
            layer.msg(res.message, {time:1*1000}, function (){
              layer.closeAll();
            });
          }else {
            layer.msg(res.message);
          }
        }
      });
    });
    $('.searchBar .layui-btn').on('click', function (){
      var type = $(this).data('type');
      console.log(type)
      active[type] ? active[type].call(this) : '';
    });
  });
</script>
</body>
</html>